/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-08-28
 * Time: 20:16
 */
class Solution {
    //162. 寻找峰值
    /*峰值元素是指其值严格大于左右相邻值的元素。
    给你一个整数数组 nums，找到峰值元素并返回其索引。
    数组可能包含多个峰值，在这种情况下，返回 任何一个峰值 所在位置即可。
    你可以假设 nums[-1] = nums[n] = -∞ 。
    你必须实现时间复杂度为 O(log n) 的算法来解决此问题。
    示例 1：
    输入：nums = [1,2,3,1]
    输出：2
    解释：3 是峰值元素，你的函数应该返回其索引 2。
    示例 2：
    输入：nums = [1,2,1,3,5,6,4]
    输出：1 或 5
    解释：你的函数可以返回索引 1，其峰值元素为 2；
    或者返回索引 5， 其峰值元素为 6。
    提示：
            1 <= nums.length <= 1000
            -231 <= nums[i] <= 231 - 1
    对于所有有效的 i 都有 nums[i] != nums[i + 1]*/

    //本质上也是找递增的最右端点
    //或者递增的最左端点
    /*public int findPeakElement(int[] nums) {
        int left=0,right=nums.length-1;
        while(left<right){
            int mid=left+(right-left+1)/2;
            if(nums[mid]<nums[mid-1]) right=mid-1;
            else left=mid;
        }
        return left;
    }*/

    public int findPeakElement(int[] nums) {
        //本质上也是找递增的最右端点
        //或者递增的最左端点

        //这个是递增的最左端点
        int left=0,right=nums.length-1;
        while(left<right){
            int mid=left+(right-left)/2;
            if(nums[mid]<nums[mid+1]) left=mid+1; //mid在顶点的左边时left要紧靠过来还要超过
            else right=mid;//另一边靠过来就行
        }
        return left;
    }

    public static void main(String[] args) {
        System.out.println(new Solution().findPeakElement(new int[]{1,2,1,3,5,6,4}));
    }
}
